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SPECIFICATION 

FIELD OF THE INVENTION 

This invention relates to the field of data organization 
systems, and more specifically to a system for organizing 
information accessible to two or more information browsing 
devices . 



BACKGROUND OF THE INVENTION 

The growth of the Internet over the past few years has been 
tremendous - both in terms of the number of people accessing 
information through the Internet and in terms of the amount and 
nature of information available through the Internet. 
Information services now available on the Internet include 
driving directions between two addresses, nearly up-to-the-minute 
stock quotes, and directories of addresses and telephone numbers. 
In addition, the Internet has been a platform for offering a 
number of services including, for example, purchasing goods and 
services, making reservations at restaurants and hotels, 
purchasing airline tickets, and other services pertaining to 
vacations and travel generally. 



# 



# 



= 



ru 
m 



Patent Application Attorney Docket P-2 1 92D3 

The accessibility of such information and services to the 
typical user is greatly enhanced by organization of such 
information and user interface tools into multimedia documents 
known generally as Web pages. Such multimedia documents can 
include images, text, audio, motion video, and active computer 
instructions (e.g., Java™ scripts) to effectively and efficiently 
communicate information to the user and to provide intuitive and 
self-explanatory user interface mechanisms. In addition, such 
multimedia documents can refer to other multimedia documents to 



lOffi provide a hierarchical information structure to suit the specific 

n| 

01 informational needs of individual users. These tools, while 



conventional, provide a highly effective information browsing 
experience for the user. 

The user's experience is frequently described as browsing or 
15 surfing since the user picks and chooses her way through the 
apparent sea of information to find her own path to her own 
information of interest. The descriptive terms of browsing and 
surfing seem particularly apt as broadband Internet access 
increases in popularity making the Internet user' s experience a 
20 truly multimedia one. 

If the general Internet is an apparent sea of information, 
accessing the Internet through a web-capable wireless telephone 
seems like a trickle of information by comparison. While many 
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Internet-capable computer systems have screen resolutions of 1024 
by 768 pixels or greater, 105-key keyboards, a pointing device 
such as a mouse or trackball, and sound capability; most 
Internet-capable wireless telephones are limited to just a few 
lines of just a few characters of alphanumeric text and input 
keypads of little more than a dozen keys. In addition, 
communications bandwidth of Internet-capable wireless telephones 
is also severely limited relative to the typical Internet-capable 
computer. If surfing in a sea aptly describes the typical user's 



10m experience through an Internet-capable computer, a typical user's 

m 

fjl experience in accessing information in an Internet-capable 

M. wireless telephone can sometimes feel like building a model ship 

O 

fd- in a bottle. 

ru 

p This limited browsing experience through mobile devices such 

15 as wireless telephones is exacerbated by the fact that the user 
is typically preoccupied with other activities while using the 
mobile device to browse information. Mobile device derive their 
value primarily from their mobility and are therefore likely to 
be used when the user is preoccupied with other activities. 
20 Mobile devices are therefore frequently used with only one hand 

and in manners in which the user's physical control of the mobile 
device is other otherwise compromised. As a result, mobile 
devices are not particularly well suited for handling large 
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amounts of information and the user's interest is typically 
highly localized to a small amount of very specific information. 

Of course, the great advantage of Internet access through a 
wireless telephone is the ability to access information of the 
apparent sea of information of the Internet while out and about - 
such as while commuting or while traveling away from home or 
while out shopping, for example. However, a better way to access 
information through an Internet-capable wireless telephone is 
highly desirable. 

SUMMARY OF THE INVENTION 

In accordance with the present invention, a user of a base 
system such as a desktop computer system organizes information 
stored on a server system for subsequent access by the user 
through a mobile device such as a wireless telephone. The server 
system is coupled to both the base system and the mobile device 
through a wide area computer network such as the Internet, for 
example . 

The user organizes information of interest using all the 
storage, bandwidth, multimedia, and user interface capabilities 
of a general purpose, modern computer system. Such information 
is gathered from local software applications on the base system 
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such as personal information manager (PIM) programs or from any 
of a number of other computer systems through the wide area 
network. Thus, in accordance with the present invention, the 
user can use full bandwidth and full multimedia and user 
interface capabilities to navigate and collect information 
through the Internet for convenient, immediate, subsequent access 
through the mobile device. 

When accessing the information through the mobile device, 
the server system provides a list of one or more data objects 
representing information previously gathered by the user, wherein 
each of the data objects can be accessed through the mobile 
device with a single user-interface gesture, e.g., by pressing a 
single key of a numeric keypad on the mobile device. 

Each of the data objects stored by the server system 
representing information gathered and submitted by the user is 
associated with a data type according to which the content of 
each data object is organized into attributes and according to 
which actions are applicable to the data object. For example, 
information of a place type data object includes a name 
attribute, a street address attribute, a city attribute, a 
telephone number attribute, etc. Actions associated with a place 
type data object include initiating a telephone call to the 
telephone number of the place, getting driving directions to or 
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from the address of the place, etc. 

Some of the actions are performed by the mobile device. For 
example, initiating a telephone call in the mobile device uses 
data of the place object already displayed on the mobile device 
in conjunction with an initiate telephone call instruction 
performed by the mobile device. Others of the actions are 
performed primarily by the server system, using the mobile device 
yj primarily for user interface purposes. For example, in obtaining 
iff driving directions relative to a place object, the server system 
10S prompts the user, through the mobile device, to specify whether 
the place data object currently displayed is the origin or 
destination of the trip for which directions are sought and for 
another place which specifies the other end of the trip. The 
system server requests directions for the trip from a map server 
15 through a wide area network such as the Internet and formats the 
resulting driving directions for display on the user's mobile 
device and sends the formatted directions for such display. 

Thus, while the Internet is generally very open-ended and 
user's are free to meander about the virtual sea of information 
20 using apt multimedia-capable computer system and apt user input 

devices, a user is free to organize information gathered from the 
Internet or from her computer for storage in a number of 
predefined data types with associated actions such that the 
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user's interaction with the Internet through a mobile device with 
limited display capabilities, limited bandwidth, and limited user 
input devices can be prearranged and customized by the user. 
Such improves dramatically the usability of Internet-capable 
mobile devices for the types of tasks they are likely to be used 
in an Internet context. 



Figure 1 is a block diagram of a wide area computer network 
in which the present invention can be implemented and which 
includes a pocket server in accordance with the present 
invention. 

Figure 2. is a block diagram of the pocket server of Figure 1 
in greater detail. 

Figure 3 is a block diagram of a pocket data set of Figure 2 
in greater detail. 

Figure 4 is a block diagram of a user configuration of 
Figure 3 in greater detail. 

Figure 5 is a block diagram of a data object of Figure 3 in 
greater detail. 

Figure 6A is a block diagram of a pocket item type of Figure 
2 in greater detail. 

Figure 6B is a block diagram showing an action engine of 
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Figure 2 in greater detail. 

Figure 7 is a screen view of a Web page which includes a 
link representing a data object in accordance with the present 
invention. 

Figures 8A-8C are screen views illustrating creation of a 
data object in accordance with the link of Figure 7. 

Figure 9 is a screen view showing a number of data objects 
which are accessible in accordance with the present invention. 

Figures 10A-E show user authentication through a mobile 
device. 

Figure 11 shows a mobile device through which a user is 
shown a list of data objects in accordance with the present 
invention. 

Figure 12 shows a mobile device through which a user is 
shown a data object in accordance with the present invention. 

Figures 13 shows a mobile device through which a user is 
provided access to actions associated with a data object in 
accordance with the present invention. 

Figure 14 is a logic flow diagram illustrating an initiate 
telephone call action in accordance with the present invention. 

Figures 15 shows a mobile device through which a user is 
provided access to actions associated with a data object in 
accordance with the present invention. 
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Figure 16 is a logic flow diagram illustrating a directions 
action in accordance with the present invention. 

Figures 17-19 and 21-26 show a mobile device in performance 
of a nearby places action in accordance with the present 
invention. 

Figure 20 is a logic flow diagram illustrating the nearby 
places action. 

Figures 27-28 are screen views of creation of a flight data 
object in accordance with the present invention. 

Figures 29-33 illustrate access by a user of the flight data 
object through a mobile device in accordance with the present 
invention. 

Figure 34 is a screen view of creation of a stock data 
2 object in accordance with the present invention. 
15 Figure 35 illustrates placement of the newly created stock 

object at the beginning of a list of data objects in accordance 
with the present invention. 

Figures 36-37 illustrate access by a user of the stock data 
object through a mobile device in accordance with the present 
20 invention. 

Figure 38 is a screen view of creation of a product data 
object in accordance with the present invention. 

Figure 39 illustrates placement of the newly created product 
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object at the beginning of a list of data objects in accordance 
with the present invention. 

Figures 40-41 illustrate access by a user of the product 
data object through a mobile device in accordance with the 
5 present invention. 

Figure 42 is a screen view illustrating copying of bulk text 
: by the user. 

ye, Figure 43 is a screen view illustrating pasting of the bulk 

e — a 

Q text by the user into a form for creation of a new data object 

W 

10nJ and selection by the user of a pocket item type for the new data 

03 

py object. 

m 

s Figure 44 is a screen view showing the parsed attributes 

O from the bulk text in accordance with the present invention. 

m 

lU Figure 45 is a screen view showing the neWly parsed and 

Q 

15 s * created data object in a list of data objects associate with the 
user . 



20 



DETAILED DESCRIPTION 

In accordance with the present invention, information 
accessible by an Internet-capable mobile device is gathered and 
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organized using an Internet-capable computer. Thus, the full 
bandwidth, multimedia capabilities, and user interface 
efficiencies of a general purpose computer is used by the user to 
collect and organize specific information of interest and to make 
5 that specific information readily accessible through a mobile 
device with limited bandwidth, display, and user interface 
capabilities. In addition, actions are associated with and 

□ actionable upon the specific information to provide significant 
hi user interface leverage, i.e., allowing the user to process such 

10Q3 specific information with very little interaction with the mobile 

01 device. To facilitate appreciation and understanding of the 

= 

M invention, a few aspects of information browsing in a wide area 
PL! network 102 are briefly described. 

□ Servers 104A-C are server computers which provide 

15 information and/or services through wide area network 102. In 
this illustrative embodiment, wide area network 102 is the 
Internet. Of course, while only three (3) servers 104A-C are 
shown, wide area network 102 can be coupled to many more servers. 
Servers 104A-C provide information and/or services through wide 

20 area network 102 to numerous users in a conventional and known 
manner. Servers 104A-C are conventional and are not described 
further herein. 

A user accesses such information and/or services through a 
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client computer system 106 which is similarly known and 
conventional. The user in this illustrative embodiment also uses 
a wireless telephone 110 which is capable of accessing 
information and/or services of servers 104A-C through wide area 
5 network using a wireless network gateway 108. Wireless telephone 
110 and wireless network gateway 108 are known and conventional. 
In this illustrative embodiment, wireless telephone 110 
implements the known and conventional Wireless Application 

3 

O Protocol (WAP) to access such information and/or services. 

W 

10^ y Wireless telephone 110 can use other protocols for data 

00 

J*( communications as well, including the Short Message Service (SMS) 
_f e protocol. 

Jrj A pocket server 112 enables the user of client computer 106 

Ffjj 

p and wireless telephone 110 to collect and organize information 
15 5 ~ for later access through wireless telephone 110 in accordance 
with the present invention. Pocket server 112 is shown in 
greater detail in Figure 2. 

Pocket server 112 includes a base system interface 202 for 
interacting with client computer 106 and other, similar Internet- 
20 capable computers of other users. Base system interface 202 

serves requests from clients, such as client computer 106, which 
are presumed to have substantial data bandwidth capabilities, 
multimedia and presentation capabilities, and considerable user 
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interface capabilities. In a manner described more completely 
below, the user of client computer 106 collects data through wide 
area network 102 (Figure 1), e.g., from servers 104A-C, and 
submits the data to base system interface 202 (Figure 2) for 
5 storage in a pocket dataset 204 for subsequent retrieval using 
wireless telephone 110 (Figure 1) . 

One of the more significant advantages of Internet-capable 

!r wireless telephones, such as wireless telephone 110, is the 

i j 

rt ability to perform telephony actions upon data retrieved from the 
10 Li Internet. In addition, one of the more significant advantages of 
the Internet is the ability to tailor information retrieved from 

^ the Internet according to data entered by the user. To preserve 

D 

m these advantages, a number of actions, e.g., pocket item actions 

ry 

q 208, are associated with various types of data received through 
15 : base system interface 202. To determine which of actions 208 
pertain to which data objects of pocket dataset 204, each data 
object stored in pocket dataset 204 is associated with one of 
pocket item types 206. Thus, pocket server 112 is able to 
distinguish an address from an airline flight reservation and 
20 different actions are associated with each. 

Pocket dataset 204 for the subject user is shown in greater 
detail in Figure 3. The subject user is a user of client 
computer 106 (Figure 1) and wireless telephone 110 in accessing 
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information and services through wide area network 102 in an 
illustrative example of the described illustrative embodiment of 
the present invention. Pocket dataset 204 (Figure 3) includes a 
user configuration 302 and one or more data objects 306. Data 
5 objects 306 comport with the object-oriented programming paradigm 
of computer software development in that data objects have both a 
state defined by one or more attributes and a behavior defined by 
Jl' one or more methods specified <for a class of objects, data 

JH objects 306 in this illustrative embodiment support neither 

n I 

10 jjg inheritance nor polymorphism, both of which are known aspects of 
P some object-oriented programming languages. In alternative 

embodiment, inheritance, polymorphism, or both can be supported 

O 

fy for data objects 306. 

m 

p User configuration 302 is shown in greater detail in Figure 

15 4. User configuration 302 includes the following ■ data fields: 

(i) user identifier/e-mail address 402; (ii) password 404; (iii) 
mobile address 406; (iv) mobile type 408; (v) mobile service 
provider 410; (vi) preferences 412; (vii) landmarks 414; and 
(viii) friends 416. 
20 User identifier 402 is an e-mail address of the subject user 

in this illustrative embodiment. Typically, this is the e-mail 
address through which the subject user is reachable through 
client computer 106 (Figure 1) . In this illustrative embodiment, 
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user identifier 402 serves the dual purposes of unique 
identification of the subject user and specifying a means by 
which a message can be sent to the subject user. In an 
alternative embodiment, the user's identifier can be independent 
of, and different from, the user's e-mail address. 

Password 404 is maintained in secrecy and is specified by 
the subject user, in combination with user identifier 402, for 
authentication purposes. 

Mobile address 406 is a network address by which the subject 
10 ffj user can receive data on wireless telephone 110. Typically, 
gl mobile address 406 is a telephone number by which wireless 

£ 

M telephone 110 is reached. Mobile type 408 specifies the type of 

Q 

ftj mobile system used by the subject user. Such types can include, 
O for example, WAP wireless telephone, SMS (Short Message Service) 

pa- 
lS wireless telephone, two-way alphanumeric pager, and personal 

digital assistant ( PDA) . Mobile service provider 410 specifies 

the organization which is responsible for delivering data to 

wireless telephone 110 (Figure 1), i.e., the owner of wireless 

network gateway 108. 

20 Preferences 412 specify one or more preferences specified by 

the subject user. In this illustrative embodiment, a single user 

preference is supported. In particular, the user can specify 

whether adding a new data object 306 (Figure 3) to the user's 



— 16 — 



# 



Patent Application Attorney Docket P-2 1 92D3 

pocket dataset 204 causes a text message summarizing the added 
object to be immediately sent to the user's mobile system, e.g., 
wireless telephone 110. Of course, other user preferences can be 
specified within preferences 412 (Figure 4). 
5 Landmarks 414 each specify a location which is frequently 

i' used by the subject user. Typically, one of landmarks 414 

specify the user's home address and another specifies the user's 

c - 

as=Si 

Q work address. Landmarks 414 provide a particularly useful 

Ly feature of the information management system according to the 

10 B present invention. Since the raison d'etre of a mobile device is 

^ that it is mobile, location-oriented services through wide area 

?f network are particularly useful. However, such location-oriented 



rtjj services frequently require that an address is specified by the 
^ user. Since an address typically includes both numerical and 

Mi 

15 alphanumerical data, specification of an address using only a 

numeric keypad of a mobile device is particularly tedious for a 
user. A numeric keypad is the sole input device for textual 
input in many mobile devices. Entering an address using a 
numeric keypad is particularly difficult if the user is 

20 distracted with other activities which is frequently the case for 
users of mobile devices. Allowing the user to enter and store 
frequently used locations as landmarks 414 greatly simplifies use 
of location-specific services as described more completely below. 
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Friends 416 each specify another user of the system 
implemented by pocket server 112. Like landmarks 414, friends 
416 enable the user to use the full user interface capabilities 
of a general purpose computer such as client computer 106 to 
5 enter frequently contacted people with whom the subject user is 
likely to share information for easy subsequent retrieval or 
reference using wireless telephone 110. in a manner described more 

lj: completely below. 

D 

q Data object 306 (Figure 3) is shown in greater detail in 

f*l 

10 r|j Figure 5. Data object 306 includes the following data fields: a 

03 

fU tyP e 502, a source 504, an accessed date 506, and content 508. 

=* 

s Type 502 specifies one of pocket item types 206 (Figure 2) 

M. 

Q as defining the attributes and actions of data object 306 (Figure 

Ft: 5 

iy 

fU 5) . Source 504 specifies the source data object 306. Data 

O 

15 H« objects can be added to pocket dataset 204 (Figure 3) from any of 
a number of sources, several of which are described more 
completely below. Briefly, the subject user can add data object 
306 by use of client computer 106 (Figure 1), the subject user 
can add data object 306 by user of wireless telephone 110, and 

20 another user can send data object 306 to pocket dataset 204 of 
the subject user, for example. Source 504 specifies from which 
of these data object 306 originated. Accessed date 506 (Figure 
5) specifies a time and date of the most recent access of the 
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substantive content or other part of data object 306. 

Content 508 represents the substantive data of data object 
306, i.e., the data intended to be accessible by the subject user 
through wireless telephone 110 (Figure 1). The substantive data 
represented by content 508 is organized in a manner specified by 
the specific attributes defined for the type of data object 306 
as specified in type 502. Accordingly, individual attributes of 
content 506 are accessible for processing in a manner described 
more completely below. 

Pocket item type 206 (Figure 2) is shown in greater detail 
in Figure 6 and includes the following data fields: (i) an 
identifier 602, (ii) attribute definitions 604, and (iii) 
attribute pattern 608 (Figure 6) . Pocket item actions 208 are 
associated with various types of data objects in a manner 
described more completely below. 

Identifier 602 uniquely identifies pocket item type 206 
among all pocket item types supported by pocket server 112 
(Figure 2) . In this illustrative example, pocket item type 206 
(Figure 6) defines an object type to which data object 306 
(Figure 5) belongs. Accordingly, type 502 specifies pocket item 
type 206 (Figure 6) by representing identifier 602 of pocket item 
type 206. 

Attribute definitions 604 define one or more attributes of 
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data represented in content 508 (Figure 5) . For example, if 

pocket time type 206 (Figure 6) represents an address, attribute 

definitions 604 specifies that content 508 (Figure 5) can include 

an address name, a street number, a street name, a city name, a 

5 state name, a country name, telephone numbers for voice and 

facsimile, and a postal code (such as a zip code in the United 

States) . Each attribute definition represented in attribute 

jf" definitions 604 can include an attribute identifier, a data type, 

3 V 

*** a maximum length, etc. 

10j/~ Generally, data objects are added in a manner described 



below in which the associated data item type and the individual 

01 

o 



ry 

component attributes of the data object are individually 
51 specified unambiguously. However, a user can also create an 
n object from copied text in a manner described below. As 

Mi 

15 2 described more completely below, individual attributes are parsed 
from such bulk text when a user creates a new data object in this 
manner. Attribute pattern 608 maps bulk text to specific 
attributes defined by attribute definitions 604. Pocket server 
112 (Figure 2) uses attribute pattern 608 to parse attributes 

20 from copied text in forming a new data object. Such parsing is 
described below in conjunction with Figures 42-45. 

Mobile system interface 210 (Figure 2) includes an action 
engine 212 which collects applicable pocket item actions 208 for 
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a particular data object. Action engine 212 is shown in greater 
detail in Figure 6B. 

Action engine 212 includes a number of action sets, e.g., 
action sets 652A-B, each of which (i) is associated with one or 
more conditions 654A-B and (ii) identifies one or more member 
actions of pocket item actions 208, e.g., pocket item actions 
208A-C. Conditions 654A-B specifying whether action sets 652A-B, 
respectively, are applicable to a particular data object. For 
H example, conditions 654A can specify that actions of action set 



ry 

10 m 652A are applicable to users whose mobile service provider 410 



Q 
n i 



(Figure 4) indicates a particular mobile service provider for 
which action set 652A is designed. Similarly, conditions 654B 
can specify that actions of action set 652B are applicable to 
P data objects of a particular data item type, e.g., places. 
15 Pocket item actions 208A-C are associated with respective 

conditions 656A-C, each of which specifies under what conditions 
the associated action applies. For example, if pocket item 
action 208A defines an initiate telephone call action, conditions 
656A can specify that pocket item action 208A is only applicable 
20 for objects which include data in content 508 (Figure 5) which 
include a voice telephone number attribute. 

In gathering actions applicable to a particular data object, 
action engine 212 (at the request of mobile interface system 210 
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- Figure 2) determines which of action sets 652A-B (Figure 6B) is 
applicable according to user configuration (Figure 4) of the 
current user and data object 306 (Figure 5) of the particular 
data object of which actions are being gathered - and therefore 
pocket item type 206 (Figure 6A) representing the particular type 
of the current data object. Of course, while only two action 
sets 652A-B and associated conditions 654A-B are shown, many more 
action sets and associated conditions can be defined within 

^ action engine 212. In this illustrative embodiment, only one of 

W 

10^ action sets 652A-B is applicable for any single action request. 

f Jf Conditions 654A-B are evaluated in a predetermined order and the 

01 

5 first of conditions 654A-B to be satisfied represents the action 
set which is determined by action engine 212 to be applicable. 

fy 

j=S Once an action set is determined by action engine 212 to be 

15* applicable, each member action of the applicable action set is 

evaluated to determine whether individual pocket item actions are 
applicable. For example, if action set 652B is determined by 
action engine 212 to be applicable, conditions 646A-C are 
individually evaluated to determine whether each of pocket item 
20 actions 208A-C, respectively, are applicable. More than one of 
pocket item actions 208A-C can be applicable. Action set 652B 
specifies a particular order of pocket item actions 208A-C to be 
presented to the user and that order is preserved in the listing 
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of available actions to the user. Such presentation is described 
more completely below. 

Object Collection and Organization Through the Base System 

Beginning with Figure 7 , use of the system implemented by 
pocket server 112 is illustrated to further facilitate 
appreciation and understanding of the present invention. Screen 
view 702 shows a Web page as presented to the subject user 
W through client computer 106 in a conventional and known manner 
10 J? using a conventional and known Web browser. Briefly, a Web 

s 5 a 

yl browser is a computer process which enables the subject user to 

!f browse the World Wide Web of the Internet. Illustrative examples 

D 

!B of known and conventional Web browsers include the Internet 

fU 

rf Explorer Web browser which is currently available from Microsoft 
15 Corporation of Redmond, Washington and the Netscape Web browser 
which is also currently available. 

The Web page of screen view 702 includes a link 704 by which 
the subject user is offered to place content 706 in her pocket. 
To facilitate an intuitive user experience, the analogy of a 
20 pocket is used. Essentially, the user is invited to make content 
706 immediately accessible through wireless telephone 110 which 
can presumably be placed in the pocket of the subject user. 

In this illustrative embodiment, content 706 is embedded in 
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the URL to which link 704 points. URLs (Universal Resource 
Locators) are known and conventional and are only briefly 
described herein for completeness. A URL specifies a network 
address of a resource, such as a Web page for example, which can 
be accessed by the user solely by activating an associated link. 
In addition to specifying the location of a resource, a URL can 
include data to be provided to the resource. Specifically, the 
entirety of the URL is passed through the known and conventional 
Common Gateway Interface (CGI) and is available to a script 
invoked by the URL. The URL of link 704 includes data specifying 
a type of data object (an address in this illustrative 
embodiment) and content 706 parsed into attributes defined by 
that type. Specifically, the URL of link 704 includes, for each 
attributed defined by attribute definitions 604 (Figure 6), data 
identifying the attribute and - associated therewith - data 
representing a corresponding portion of content 706 (Figure 7) . 
As described above, parsing content into attributes enables 
actions to act upon individual attributes of the content. 

Upon activation of link 704 by the subject user using 
conventional user interface techniques - typically involving 
physical manipulation of one or more user input devices and a 
single user interface gesture such as clicking on link 704, base 
system interface 202 (Figure 2) of pocket server 112 presents a 
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Web page to client computer 106 (Figure 1) resulting in screen 
view 802 (Figure 8A) in the Web browser used by the subject user. 
Screen view 802 shows content 706 (Figure 7) organized into 
attributes defined for the Place type for confirmation by the 
5 subject user. The attribute organization shown in screen view 
802, namely, the particular attributes shown as parsed from 
content 706 (Figure 7) , is specified by and embedded within the 
□ URL of link 704. 

yj In addition to a link embedded in a Web page, the subject 

flj 

lOffl user can cause data stored locally within client computer 106 to 
CP be made accessible through wireless telephone 110. For example, 

= 

M a Personal Information Management (PIM) process running within 

O 

m client computer 106 can store place information such as addresses 

jJJ 

and telephone numbers and can store notes of the subject user. 

f=v 

15 In addition, such information is frequently organized in a 

structural manner, i.e., including attributes. Furthermore, 
since such PIM processes can be configured using a general 
purpose programming language with the full capabilities of client 
computer 106 available to such PIM processes, sending data 

20 organized into attributes defined by attribute definitions 604 
(Figure 6) to pocket server 112 is possible. To enable storage 
of such information in pocket dataset 204 (Figure 2), the PIM 
process for the subject user first queries pocket server 112 



— 25 — 



Patent Application Attorney Docket P-2192D3 

through wide area network 102 for attribute definitions 604 for a 
particular type of data according to the type of data currently 
accessed by the subject user. The PIM process organizes the PIM 
content selected by the subject user according to the attribute 
definitions received from pocket server 112 and sends the content 
to pocket server 112. 
V In the same manner that link 704 (Figure 7) communicates the 

2 individual component attributes of content 706, a WML link in the 

0 

y form passed through wireless network gateway 108 according to the 

m 

10?; WAP protocol can similarly communicate individual component 

attributes of content. Similarly, such content can be stored by 
mobile system interface 210 in the manner base system interface 
202 stores content 706 as described herein. Thus, content can be 
U added by the subject user to her pocket dataset 204 simply and 
15 easily from browsing the Internet with client computer 106 or 

wireless telephone 110 or from local processes executing within 
either client computer 106 or wireless telephone 110. 

Whether from a process or by activation of a link such as 
link 704 (Figure 7), screen view 802 (Figure 8A) includes an HTML 
20 form by which the subject user can confirm addition of a data 

object representing the shown information into pocket dataset 204 
(Figure 2) for the subject user by effecting a single user 
interface gesture, namely, clicking on confirmation button 804. 
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Alternatively, the subject user can modify the parsed content, or 
even change the type of data object, prior to adding the content 
by clicking of confirmation button 804. HTML forms interact with 
CGI scripts in a known and conventional manner which is not 
5 described further herein. If the newly created data object is a 
result of usage of a mobile device such as wireless telephone 
110, a generally analogous user interaction with the mobile 

~ device confirms or alters the newly created data object. 

\=J 

H Upon clicking confirmation button 804, base system interface 

nj 

10^ 202 (Figure 2) of pocket server 112 presents a Web page to client 

IP computer 106 (Figure 1) resulting in screen view 812 (Figure 8B) . 

La Screen view 812 includes an HTML form by which the subject user 

Q 

m can specify one of a number of folders of dataset 204 into which 

m 

q to place the newly created data object. Folders are described 
15 more completely below. The HTML form of screen view 812 also 

enables the subject user to send the newly created data object to 
one or more friends, to send a message summarizing the data 
object, to return to screen view 802 (Figure 8A) to edit the data 
object, to add the data object to object dataset 204 (Figure 2), 
20 or to quit without adding any data object. Such provides the 
user with an intuitive interface to manage many situations 
involving data objects. 

Upon adding the newly created data object to object dataset 
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204, base system interface 202 sends a Web page to client 
computer 106 which results in screen view 822 (Figure 8C) 
confirming addition of the newly created data object. 

Figure 9 shows a screen view 902 in which the subject user 
5 can view the contents of her pocket, i.e., the data objects 

represented in object dataset 204 (Figure 2) associated with the 
subject user. Row 904 (Figure 9) shows content 706 (Figure 7) 
£ organized according to the attributes of the particular type of 
G object. In addition, rows 906 (Figure 9) and 908 show two 
105 landmarks, e.g., landmarks 414 (Figure 4), of the subject user. 
|| The data object represented by row 904 (Figure 9) is now 
f. accessible by the subject user through wireless telephone 110 
Q 

m (Figure 1) . 

m 

O 

if Object Access Through the Mobile System 

As shown in Figure 2, wireless telephone 110 interacts with 
pocket server 112 though mobile system interface 210. In this 
illustrative embodiment, wireless telephone 110 and mobile system 
interface 210 communicate with one another through the Wireless 

20 Application Protocol (WAP) using Wireless Markup Language (WML) 
documents and/or scripts. WAP and WML are both known and 
conventional and are not described further herein. It should be 
appreciated however that WML scripts can include instructions 
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which can be carried out by a mobile device such as wireless 
telephone 110 thereby defining a behavior of wireless telephone 
110. 

WML documents are briefly described to facilitate 
5 understanding and appreciation of the present invention. Since 
the display screens of most mobile devices are quite small and 
the bandwidth to and from most mobile devices is quite limited, 

y 

q more than one display is typically sent at one time. Each 

6 

hi display is referred to as a card and the collection of cards 

ry 

\0m defined by a single WML document is called a deck. Each card can 

m 

m include one or more links to other cards much like HTML documents 

s 

h* can include hypertext links. Such WML links can be to cards 

O 

fy within the same deck or within a different deck. Links to cards 

fy 

O within the same deck are much like HTML links to anchors within 
15 the same HTML document containing the link. Users browsing the 
World Wide Web experience this routinely as a link within a 
particular Web page causes a different portion of the same Web 
page to be displayed. One difference however is that, while a 
user viewing a Web page in HTML can access all portions of the 
20 Web page, cards within a single deck are treated as distinct from 
one another and generally can only be viewed one at a time. 

One advantage of WML decks is that related content can be 
organized into multiple views but transmitted to a mobile device 
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in a single network transaction. WML decks are used in a manner 
described more completely below to send multiple views to the 
subject user in a single network transaction. 

Upon initial contact with mobile system interface 210, the 
5 user of wireless telephone 110 is authenticated. Wireless 

telephone 110 contacts mobile system interface 210 by supplying a 
WAP URL which uniquely identifies mobile system interface 210 

M» within wide area network 102 (Figure 1) . In the following 

D 

O authentication transaction, mobile system interface 210 (Figure 

U 

10*^ 2) (i) identifies the user of wireless telephone 110 with a 

03 

[P reasonable degree of certainty and (ii) determines that access by 
wireless telephone 110 is to be directed to the particular one of 
pocket datasets 204 associated with the identified user. 

ru 

rU Wireless telephone 110 is shown in greater detail in Figure 

P 

1^ 10A and includes a keypad 1002 and a display 1004. Keypad 1002 
is used by the subject user in a conventional manner to enter 
data to be supplied to mobile system interface 210 (Figure 2) 
according to the WAP protocol. Display 1004 is controlled 
according to the WAP protocol to present information to the 

20 subject user. As shown in Figure 10A, display 1004 displays a 
welcome message from mobile system interface 210 (Figure 2) . 

When the subject user presses key 1006 (Figure 10A) to 
indicate that the welcome message has been read, mobile system 
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interface 210 (Figure 2) responds by requesting identification of 
the subject user in the form of the address of wireless telephone 
\. 110, e.g., the telephone number by which wireless telephone 110 
can be reached. The request is presented to the subject user as 
5 a text message in display 1004 as shown in Figure 10B. The 

subject user enters the address of wireless telephone 110 using 
keypad 1002 and conventional user interface techniques. In an 
q alternative embodiment, mobile system interface 210 gets the 
hj address of wireless telephone 110 through wireless network 
10 yQ gateway 108 (Figure 1) using conventional techniques and the 

ru 

yl interaction shown in Figure 10B is obviated. 

M» Mobile system interface 210 (Figure 2) requests, as further 

o 

fy identification, the user's e-mail address as a user identifier as 

5= 2 

O shown in Figure 10C. In an alternative embodiment, the user 

SS5SS! 

15 identifier can be different from the user's e-mail address and 

that alternative identifier is entered in an analogous manner to 
that shown in Figure 10C. In another alternative embodiment, the 
user is identified according to the address of wireless telephone 
110, whether manually entered as described above with respect to 

20 Figure 10B or automatically determined by mobile system interface 
210 through wireless network gateway 108. 

Authentication of the .subject user is completed by 
requesting (by mobile system interface 210) that the user supply 
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as associated password as shown in Figure 10D. Authentication is 
successful upon determination by mobile system interface that the 
password supplied by the subject user matches the password 
specified for the user identified as shown in Figure IOC. As 
5 described above, user identification and passwords are associated 
with one another by being stored respectively in identification 
402 (Figure 4) and password 404 of the same user configuration 
^ 302. 



- message. The subject user acknowledges confirmation by pressing 

0 1 

f 8 key 1006. It should be appreciated that authentication by the 

5t subject user is required infrequently. In one embodiment, user 

= y 

q. authentication is required once each time the user turns wireless 
15" telephone 110 on - i.e., once each time wireless telephone 110 

establishes new contact with wireless network gateway 108 (Figure 
1) . In an alternative embodiment, user authentication is 
required only when the subject user changes the mobile device 
with which the subject user accesses her pocket. 
20 After authentication, if necessary according to the 

particular embodiment, the subject user is presented with a list 
of data objects in the user's pocket as shown in Figure 11. In 
particular, mobile system interface 210 (Figure 2) retrieves the 
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one of pocket datasets 204 associated with the subject user and 
retrieves therefrom all data objects 306 (Figure 3) from that 
pocket dataset 204. For each of the data objects 306, mobile 
system interface 210 (Figure 2) summarizes content 508 (Figure 5) 
i according to the type of data object. Mobile system interface 
210 (Figure 2) creates a WML document which includes the 
summaries of a number of the data objects and presents the WML 

□ document to wireless, telephone 110 for presentation in display 

O 

W. 1004 (Figure 11) . In constructing the WML document, mobile 
system interface 210 incorporates any non-standard WML 
idiosyncrasies of the particular model of wireless telephone 110. 
As WAP is relatively new, each model of mobile device supporting 
RJ WAP can have idiosyncrasies which deviate from the emerging WAP 
O standard. Compensating for such idiosyncrasies is a matter of 
15 routine engineering and depends on the particular model of mobile 
device . 

When presented with the WML document resulting in the 
display of Figure 11, the user can select any item from the list 
by scrolling up and/or down in a conventional manner or by 
20 pressing the number key of keypad 1002 associated with the 

desired item. In this illustrative example, the subject user 
presses the "2" key to select the data object associated with the 
numeral "2" in the displayed list. 



ru 
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According to WAP and the particular configuration of the WML 
document sent by mobile system interface 210, pressing of the "2" 
key (Figure 11) by the subject user sends a signal from wireless 
telephone 110 to mobile system interface 210 identifying the data 
5 object associated with the numeral "2" in the displayed list 

(Figure 11) . In response thereto, mobile system interface 210 
(Figure 2) retrieves the data object 306 selected by the user. 
V* In addition, mobile system interface 210 retrieves content 508 

5 (Figure 5) of the selected data object 306 and builds a WML 

UI-. 

lOrO document representing content 508 to the subject user and sends 

M 

SJ.J 

fU the WML document to wireless telephone 110 for display as shown 

m- 

* ' in Figure 12. Content 508 (Figure 5) is organized according to 

M, 

□ attribute definitions 604 (Figure 6) of the pocket item type 206 

m 

nJ to which the selected data object 306 (Figure 5) belongs 
15K according to type 502. As shown in Figure 12, the content of the 
selected data object is represented such that the name attribute 
is listed at the top and displayed in bold text and the street 
address, city, state, and postal code attributes are arranged to 
represent an address in a standard address format. Thus, the 
20 subject user is presented with summary confirmation of the 
selected data object. 

The subject user can act upon the selected data object by 
pressing key 1006 which sends a message to mobile system 
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interface 210 (Figure 2) requesting access to actions applicable 
to the selected data object. As shown, a textual description 
"Go" is associated with key 1006. In an alternative embodiment, 
the textual description "Actions" is associated with key 1006. 

In response to the request for applicable actions, mobile 
system interface 210 retrieves applicable actions in conjunction 
with action engine 212 in the manner described above and presents 
the list of applicable actions to the user. To do this, mobile 
system interface 210 builds a WML document which identifies the 
10fi applicable actions and provides the subject user with a user 
m. interface mechanism to activate any of the applicable actions. 
j\ Each action in this illustrative embodiment includes both a 

short description and a collection of computer instructions and 
data defining behavior of the action. Each collection of 
15 computer instructions is designed to be performed either by 

mobile system interface 210 (Figure 2) or by a mobile device such 
as wireless telephone 110. The WML document includes the brief 
description of each of the applicable actions and, associated 
within the WML document in the form of a WML script in this 
20 illustrative embodiment, actions to be taken by wireless 

telephone 110 upon activation of each of the actions. If the 
action is defined by computer instructions to be carried out by 
wireless telephone 110, those computer instructions are included 



Hi 
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in the WML document as a WML script. Conversely, if the action 
is defined by computer instructions to be performed by mobile 
system interface 210, data identifying the action is embedded in 
a URL which is associated with the brief description of the 
5 action. Thus, activation of an action to be performed by mobile 
system interface 210 causes a URL which identifies the action to 
be sent to mobile system interface 210 and the action can then be 
H performed . 

• O Figure 13 shows the resulting display of the WML document, by 

* " I 

10W which mobile system interface 210 allows the user to invoke an 
[Jf action. Display 1004 includes a brief description of the actions 
applicable to a place data object. In particular, those actions 
include (i) initiating a telephone call to the place, (ii) 

obtaining driving directions relative to the place, (iii) 

u. 

locating other nearby places, and (iv) sending the place object 
to a friend. The subject user invokes any of the listed actions 
by the single user interface gesture, of pressing a numeral key of 
keypad 1004 corresponding to a numeral associated with the 
intended action or by other standard and conventional user 
20 interface techniques. 

The call action, i.e., the action associated with the 
numeral "1" by which the subject user initiates a telephone call 
to the place, is performed by wireless telephone 110 and is 



^ :: 
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O 
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therefore embodied in a WML script in the WML document resulting 
in the display shown in Figure 13. Performance of the call 
action by wireless telephone 110 as specified in the WML script 
is illustrated by logic flow diagram 1400 (Figure 14) . 
5 In step 1402, wireless telephone 110 loads the voice 

telephone number of the current place data object. In 
constructing the WML script which defines the behavior of 
^ wireless telephone 110 in performing the call action, mobile 
Q system interface 210 retrieves the voice telephone number from 
10 2 the place object as defined by attribute definitions 604 (Figure 

Of 6) in the pocket item type 206 which defines the place type of 

y i 

: e data object. Mobile system interface 210 (Figure 2) embeds the 

voice telephone into the WML script such that wireless telephone 
2/ 110 does not require direct access to pocket dataset 204 and does 
15 K " not require direct awareness of the various type attributes and 
actions. Instead, the telephone number of the current place is 
written directly into the WML script and that telephone number is 
loaded for dialing within wireless telephone 110 in step 1402 
(Figure 14) . 

20 In step 1404 of the WML script for the call action, wireless 

telephone 110 initiates a telephone call to the number loaded in 
step 1402. Thus, three user interface gestures are required to 
both select the current place from the subject user's pocket and 
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to dial the associated telephone number. Specifically, pressing 
the numeral "2" key of keypad 1002 (Figure 11) selects the place 
from the list of data objects, pressing key 1006 (Figure 12) 
requests a list of applicable actions, and pressing the "1" 
numeral key of keypad 1002 (Figure 13) invokes the call action to 
place the call. This is a dramatic improvement over direct 
dialing and a significant improvement over other mechanisms for 
dialing of previously stored telephone numbers. 

The subject user invokes the directions action of the 
current place object from the list of actions as shown in Figure 
15. Performance of the directions action provides driving 
directions to the subject user relative to the current place. In 
this illustrative embodiment, the directions action is performed 
by mobile system interface 210 (Figure 2) and the behavior of 
mobile system interface 210 in performing the directions action 
is illustrated by logic flow diagram 1600 (Figure 16) . 

In step 1602, mobile system interface 210 (Figure 2) queries 
the subject user whether the current place is the origin or 
destination of the trip. Figure 17 illustrates the display of 
the WML document by which mobile system interface 210 queries the 
subject user through wireless telephone 110. The subject user 
presses the "1" key to indicate that the subject place is the 
destination or alternatively presses the "2" key to indicate that 
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the current place is the origin of the trip. 

In step 1604, mobile system interface 210 queries the 
subject user for data specifying the other end of the trip. If 
the subject user has indicated that the current place is the 
destination of the trip, mobile system interface 210 sends a WML 
document to wireless telephone 110 querying the user for the 
origin of the trip as shown in Figure 18. Conversely, if the 
subject user has indicated that the current place is the origin 
of the trip, mobile system interface 210 sends a WML document to 
wireless telephone 110 querying the user for the destination of 
the trip. In either case, the subject user is provided the 
opportunity to immediately select any of landmarks 414 (Figure 4) 
of the subject user as other end of the trip for which directions 
are sought. Thus, the user can specify both ends of the trip 
without specifying any address through the very limited keypad 
1002 for which data entry is provided in wireless telephone 110. 
In addition, the user is provided with a user interface option 

(see "New..." associated with the "1" key in Figure 18) to 
specify a location other than those represented in landmarks 414 

(Figure 4) of the subject user. 

In step 1606 (Figure 16), mobile system interface 210 

(Figure 2) submits the origin and destination of the trip as 

specified by the subject user to a map server through wide area 
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network 102 (Figure 1). As used herein, a map server is a 
network server, such as any of servers 104A-C, which provides 
navigation information such as maps and driving directions 
between two locations. Map servers are known and conventional 
5 and are not further described herein. Examples of currently 

available map servers are those provided by Vicinity Corporation 
of Sunnyvale, California ( http://www.mapblast.com ) ; MapQuest.com, 
O Inc. of New York City, New York ( http: //www .mapquest . com ) ; and 
UJ Yahoo! Inc. of Sunnyvale, California ( http://m aDs.vahoo.com/) . 

m 

10® In step 1608 (Figure 16), mobile system interface 210 

ru 

P (Figure 2) receives the driving directions from the map server. 

jf In step 1610 (Figure 16), mobile system interface 210 (Figure 2) 

y 

[Jf incorporates the received driving directions into one or more WML 
Q documents for presentation to the subject user through wireless 
15 telephone 110 and sends the WML document with the driving 
directions to wireless telephone 110 in step 1612. 

In an alternative embodiment, mobile system interface 210 
(Figure 2) receives driving directions from the map server in a 
format which is suitable for presentation for wireless telephone 
20 110, e.g., in a WAP-compliant format such as WML. In this 

alternative embodiment, mobile system interface 210 can send the 
received driving directions directly to wireless telephone 110, 
obviating step 1610. 
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Thus, by allowing the subject user to select from places 
previously collected through client computer 106 to specify both 
ends of the trip for which driving directions are sought, the 
subject user can get driving directions by applying just a few 
user interface gestures. 

The subject user invokes the nearby places action of the 
current place object from the list of actions as shown in Figure 
19. Performance of the nearby places action provides the subject 
user a list of places which are near the current place. In this 
lte illustrative embodiment, the nearby places action is performed by 
mobile system interface 210 (Figure 2) and the behavior of mobile 
system interface 210 in performing the nearby places action is 
illustrated by logic flow diagram 2000 (Figure 20) . 

In step 2002, mobile system interface 210 (Figure 2) builds 



Uf 



5= H 

m 



ru 

□ 

15 a hierarchical WML document which is organized as a deck of cards 



in the manner described above. One card includes all categories 
of places from which the subject user can chose a desired 
category. For each of the categories, the deck includes another 
card representing all subcategories from which the subject user 
20 can more particularly specify the desired category. Mobile 

system interface 210 sends the WML document to wireless telephone 
110 for browsing by the subject user. 

The resulting display of the WML document is shown in Figure 
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21 and shows a number of categories from which the subject user 
can choose. The categories include: food, fun, travel, and 
shopping. Of course, other and different categories can be 
presented to the subject user. Similarly, more or fewer 
categories can be presented to the subject user. In addition to 
the listed categories, the WML document includes an option for 
the subject user to specify a name of a desired place. 

Figure 22 shows that the subject user has selected the food 
category, thus retrieving a food category card within the WML 
document to present the food subcategories as shown in Figure 23. 
The food subcategories of this illustrative embodiment include 

e 

if restaurants, pizza, coffee shops, and Italian food. More or 

fewer, other and different subcategories can be presented to the 
subject user. As shown in Figure 23, the subject user chooses 
15 the coffee shop subcategory in this illustrative example. 

In selecting the subcategory, the subject user invokes a 
link associated with the subcategory which communicates the 
category and subcategory to mobile system interface 210 (Figure 
2) . In an alternative embodiment, the user is permitted to 
20 specify a name or partial name of a particular place for which 
the subject user is searching and this name or partial name is 
similarly communicated to mobile system interface 210. 

Mobile system interface 210 receives the category and 



ni 
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subcategory from the subject user in step 2004 (Figure 20) . In 
step 2006, mobile system interface 210 (Figure 2) sends the 
address of the current place and the category and subcategory and 
any specified name or partial name to a directory server, which 
can be one of servers 104A-C. Directory servers are known and 
conventional. Examples of currently available directory servers 
include the Switchboard directory server of Switchboard Inc. of 
Westboro, Massachusetts ( htto: //www. switchboard. com ) ; the At Hand 
directory server of the At Hand Network ( httpj //w ww. athand. com) ; 
lOjj: and the Yellow Pages directory server of YellowPages.com Inc. of 
San Francisco, California ( http://www.vello wpaaes.com) . Briefly, 
a directory server serves search requests for directories of 
regional businesses and residences - much like an ordinary paper 
telephone directory book. However, computer directory servers 
15* perform text-based and regional based searches of such addresses 
and telephone numbers. Mobile system interface 210 (Figure 2) 
limits the result of the directory search to locations within a 
predetermined distance of the current place and matching any 
specified whole or partial name. Mobile system interface can 
20 specify that the directory server so limits the results or can 
filter the results itself to exclude locations more than the 
predetermined distance from the current place. In this 
illustrative embodiment, the predetermined distance is 5 miles. 
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In an alternative embodiment, there is no limit on the distance 
of listed places from the current place. Instead, proximity is 
limited only by the user's willingness to look down the list as 
listed places increase in distance from the current place. 
5 ' in response to the directory search request, mobile system 

interface 210 receives a list of places in step 2008 (Figure 20) . 
In step 2010, mobile system interface 210 (Figure 2) sends the 
S received places to the subject user. In particular, mobile 
R system interface 210 builds a temporary object dataset which 
lOjl includes the places received in step 2008 (Figure 20) . Each of 



the places is parsed into attributes defined by the place type, 
e.g., by attribute definitions 604 (Figure 6). In addition, 
actions similar to those described above with respect to place 



ni 

q objects are associated with the places received in step 2008 
15 (Figure 20). Mobile system interface 210 (Figure 2) builds a WML 
document which includes a list of the received places as one or 
more cards and a card describing each place by at least name, 
address, and telephone number in this illustrative embodiment. 
Finally, to send the received places to the subject user in step 
20 2010, mobile system interface 210 sends the WML document to 
wireless telephone 110 in step 2012. 

The resulting display is shown in Figure 24. The subject 
user is presented with the first four (4) nearby coffee shops and 
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an option to see more nearby coffee shops. In this illustrative 
embodiment, the nearby places are sorted by proximity to the 
current place. Upon selecting the first listed coffee shop, 
wireless telephone 110 presents the card of the WML document 
5 describing the selected coffee shop as shown in Figure 25. By 
activating the actions menu, the subject user can invoke any of 
the actions associated with a place as shown in Figure 26 It 

O should be appreciated that the nearby places action can therefore 

O 

W be performed recursively. Specifically, the subject user can 

FtJ 

10p subsequently request places near the selected coffee shop. 

ni 

^ It should also be noted that an extra action not associated 

with place objects of pocket dataset 204. In particular, the 
subject user can cause the selected place shown in Figure 25 to 
be added to the pocket of the subject user, e.g., to be added to 
15 . pocket dataset 204 (Figure 3). This action is represented in the 
display of Figure 26 as the "PocketThis ! " action. Associated 
with the "PocketThis ! " action description is a link in the WML 
document which embeds the individual data attributes 
corresponding to the nearby place in the manner described above 
20 with respect to link 704 (Figure 7) for addition of the 
corresponding place as a new data object. 

Thus, the nearby places action is quite powerful and 
requires only a few user interface gestures by the subject user 



D 

ru 

m 
P 



— 45 — 



Patent Application Attorney Docket P-2 1 92D3 

to locate various types of establishments near a place of 
interest. 

Figure 19 also shows an action in which the selected place 
object (as shown in Figure 12) is sent to a pocket dataset 
5 associated with another user. In performing the send-to-f riend 
action, the subject user is presented with a list of people 
identified by friends 416 (Figure 4) . The user selects from the 
M list or specifies a different person to which the current place 

O is to be sent. Upon identification of the destination person, 

W 

10pJ mobile system interface 210 (Figure 2) locates the pocket dataset 

W for the identified person and adds a data object representing the 

on 

* current place to that pocket dataset. 

H» 

O The preceding description pertains to data objects of the 

2 place type defined in this illustrative embodiment of the present 
invention. Other types of data objects defined in this 
illustrative embodiment include data objects representing 
flights, products, stocks, and notes. 

Flight Objects 

20 Another type of data object specified in pocket item types 

206 (Figure 2) is a flight. Screen view 2700 shows a dialog box 
accessible by the subject user through client computer 106 and 
illustrates the kind of attributes specified by attribute 
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definitions 604 (Figure 6) for the flight type of data object. 

Box 2702 shows that the type of data object represented is a 
flight. This type can be specified in a URL activated by the 
subject user in the manner described above with respect to Figure 
7 or can be manually selected by the subject user using 
conventional user interface techniques. 

In box 2704, a name of the flight data object is specified. 

ti The name of the flight data object identifies the data object to 

Li 

St the subject user and should be distinct from names of other data 

CO 

10m objects in the pocket dataset associated with the user. The 

r' flight represented by the flight data object is sometimes 

M 

q referred to herein as the subject flight. 

fij 

fy Boxes 2706-2714 represent the first or only leg of the 

a 

p* subject flight. Additional boxes are provided for an optional 
15 second leg of the subject flight. Additional legs can also be 
specified. 

The airline providing the first or only leg of the subject 
flight is specified in box 2706. Boxes 2708 specify the date of 
the first or only leg of the flight, and the flight number is 
20 specified in box 2710. Boxes 2712 and 2714 specify the origin 

and destination airports, respectively, of the first or only leg 
of the subject flight. 

In response to submission of the information depicted in the 
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HTML form of screen view 2700, base system interface 202 (i) 
creates a data object such as data object 306 (Figure 5) 
representing the flight and (ii) prepares and sends a 
confirmation Web page which results in screen view 2800 (Figure 
5 28) on client computer 106. Content 508 (Figure 5) of the flight 
data object is summarized by textual summary 2802 (Figure 28) . 
Upon confirmation by the subject user that the information should 

H be added to her pocket dataset 204, base system interface 202 

O 

O (Figure 2) adds the flight data object to the pocket dataset 204 

: s 

ill 

10W of the subject user. 

W Figure 29 illustrates access of the flight data object by 

m 

B the subject user through wireless telephone 110. Display screen 

? 1006 shows the flight data object, indicated by the name "Boston 

ni. 

2 Flight/' listed among other data objects included in the pocket 

1=3 

15" dataset 204 of the subject user. Those other data objects 

include two place data objects corresponding to the destination 
of the flight data object, namely, Boston, Massachusetts. The 
two place data objects include one named "Hilton" and 
representing a Hilton hotel in the Boston area and another named 

20 "Aujourd'hui Restaurant" and representing a restaurant in the 
Boston area. 

Upon selection of the flight data object by the subject 
user, mobile system interface 210 (Figure 2) receives the URL 
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from wireless telephone 110 so indicating. In response to the 
URL indicating that the user wishes to see the flight data 
object, mobile system interface 210 constructs a WML deck which 
includes a top-level menu card, a details menu card, a flight 
5 details card, and a flight actions card. Mobile system interface 
210 sends the WML deck to wireless telephone 110 to make the 
substance of the flight data object, and all associated actions, 
^ available to the subject user. 

D Presentation of the WML deck causes the initial card 

UJ 

10^ representing the top-level menu to be displayed in display 1006 
of wireless telephone 110 as shown in Figure 30. The top-level 
menu includes the following options: "Show Details, " "Send to 
Friend," "Erase," and "[My Pocket]." Selection of the "[My 
Pocket]" option causes mobile system interface 210 to return to 
15™"- the initial WML deck in which all pocket data objects are listed 
for the subject user as shown in Figure 29 and described above. 
Selection of the "Erase" option causes the flight data object to 
be removed from the pocket dataset 204 of the subject user. In 
this illustrative embodiment, the subject user is asked to 
20 confirm the removal before the removal is effected. Selection of 
the "Send to Friend" option causes the flight data object to be 
sent to another user in the manner described above for place 
objects . 



□ 
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Selection of the "Show Details" option activates a link to 
the details menu card of the WML deck, the results of which are 
shown in Figure 31 in display 1006. The details menu card 
includes an option to view the description of the subject flight, 
a textual line representing the source of the flight data object, 
an "[Actions]" option, and a " [My Pocket]" option which acts in 
the manner described in conjunction with Figure 30. 

Activation of the description option by the subject user 
activates a link referring to the flight details card resulting 



lOfS in the display shown in Figure 32 which includes the substantive 

Pi 

i?, content of the flight data object, namely, the airline, the 

L= flight number, the date, and departure and arrival information. 

□ 

ni When the subject user no longer needs to see the detailed 



information of Figure 32, the subject user presses key 1006 and 
returns to the details menu card as shown in Figure 31. 

Activation of the "[Actions]" option by the subject user 
activates a link referring to the actions menu card resulting in 
the display shown in Figure 33. As shown in Figure 33, four (4) 
actions are associated with flight data objects: (i) call the 
20 airline, (ii) obtain driving directions relative to the origin, 

(iii) obtain driving directions relative to the destination, and 

(iv) update flight information. 

The call action is generally analogous to the call 'action 
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described above with respect to place data objects with the 
exception that mobile system interface 210 retrieves the 
telephone number for the airline of the flight data object from 
previously stored contact information for those airlines 
5 supported by pocket server 112. 

Both driving directions actions are generally analogous to 
the directions action for place data objects described above. 

M However, instead of retrieving location information for the map 

b 

o server from a place data object, mobile system interface 210 

Iffy (Figure 2) supplies data identifying the particular airport as 

fU one of the locations defining the trip for which directions are 

yi 

£ sought, which is sometimes referred to herein as the subject 

H 

Q trip. For example, in performing the action which obtains 

RJ 

rtj driving directions relative to the origin of the subject flight, 
lA* mobile system interface 210 identifies the airport of origin as 
one of the two locations defining the subject trip. Some map 
servers accept airport identification as sufficient specification 
of a location defining a trip. Accordingly, mobile system 
interface 210 supplies a standard 3-letter (or 4-letter for 
20 international airports) identifier of the airport specified by 
the flight data object as the airport of origin as the 
destination of the subject trip in this illustrative embodiment. 
In an alternative embodiment, mobile system interface 210 
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determines an alternative specification of the location of the 
airport, such as an address or latitude/longitude coordinates for 
example, and supplies the alternative location specification to 
the map server to obtain driving directions. 
5 In the action by which the subject user obtains driving 

directions relative to the airport of origin, mobile system 
interface 210 presumes that the airport of origin is the 

H destination of the subject trip and allows the subject user to 

O 

O specify an origin of the subject trip, i.e., from where the 

yy 

ltfU subject user would like directions to the airport of origin. The 

05 

Ri user specifies the origin of the subject trip in the manner 



described above with respect to the directions action of place 
D data objects, namely, by selecting a place from the user's pocket 

ry 

[r dataset 204 or by specifying an address or other location 

O 

1^. designation. In an alternative embodiment, mobile system 

interface 210 allows the user to specify that the airport of 
original for the subject flight is the origin of the subject trip 
such that the subject user can obtain directions from the airport 
of origin to another place. Such is useful if the subject user's 

20 flight has been delayed a significant amount of time and the 

subject user would like to leave the airport of original to get 
something to eat. 

The action by which the subject user can obtain driving 
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directions relative to the destination airport is analogous to 
the action by which the subj'ect user can obtain driving 
directions relative to the airport of origin except that (i) the 
destination airport is one of .the two locations defining the 
5 subject trip and (ii) the destination airport is presumed to be 
the origin of the subject trip in this illustrative embodiment. 
In an alternative embodiment, the subject user is free to specify 
N ; that the destination airport is: the destination of the subject 
H trip and to specify a different origin of the subject trip. 
lQl| In performing the action which updates flight information 

for the subject flight, mobile system interface 210 submits data 
representing the airline and flight number of the subject flight 
to an airline reservation server' through wide area network 102. 
Airline reservation servers are well-known and conventional and 
.F are not described further herein:. flny of servers 104R-C can be 
an airline reservation server. In response to the data 
representing the airline and flight number, mobile system 
interface 210 receives updated information regarding the 
scheduled time of departure and, in some embodiments, gate 
20 information for the subject flight. 

Upon receiving the updated flight information, mobile system 
interface 210 constructs a new WML deck which includes the 
updated flight information and sends the new WML deck to wireless 



RJ 

ry. 
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telephone 110 for display to the subject user. In this 
illustrative embodiment, the new WML deck is configured such that 
the subject user initially sees the flight details card as shown 
in Figure 32 such that the updated information is immediately 
5 • available to the subject user without further interaction with 
wireless telephone 110. 

Thus, the most common things a person wants to know about a 
jf flight are made immediately accessible to the subject user 
P through wireless telephone 110V • Specifically, the subject user 

ldjf has immediate and easy access to such information as (i) a voice 

yy . 

l M conversation with the airline' of the subject flight, (ii) 

directions to the airport of origin, (iii) directions from the 
destination airport, and (iv) updated flight information. It 



J=S should also be noted that this information comes from different 
lfT servers through wide area network 102. For example, driving 

directions can be provided by a different server controlled by a 
different entity than that which provides updated flight 
information. In addition, the accessibility of this information 
is significantly enhanced by the ability to use previously 
20 entered places to define trips for which directions are sought. 



Stock Objects 

Pocket item types 206 (Figure 2) of pocket server 112 define 
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a stock type of data object t6 represent an investment of 
interest to the subject user. The subject user can specify data 
corresponding to attributes defined by attribute definitions 604 
(Figure 6) of the stock type through client computer 106 using a 
5 dialog box such as that shown in screen view 3400 (Figure 34). 
The subject user can specify each of the attributes directly 
using conventional user interface techniques. Alternatively, the 
, 5 various attributes can be pre-s'pecif ied and embedded in a URL in 

if the manner described above with respect to Figure 7. 

l.i 

1CC1 Box 3402 (Figure 34) indicates that the represented data 

01 

object is a stock data object. Box 3404 specifies in which 

01 

J" public market the subject stock is traded. The subject stock is 

u 

p the stock represented by the stock data object. Box 3406 

fjj specifies the ticker symbol of the subject stock. Box 3408 

O' 

1JU includes any notes the subject user wishes to add to the stock 
data object. For example, the subject user can note a date, 
price, and number of shares of a purchase made of the subject 
stock. Alternatively, or in addition, the subject user can 
record notes regarding reasons for investing, thoughts regarding 

20 potential growth, and/or general thoughts regarding the welfare 

of the underlying corporation. Upon pressing confirmation button 
3410 by the subject user, base system interface 202 receives the 
HTML form data shown in Figure 34 from client computer 106 and 
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constructs therefore a stock data object and adds the stock data 
object to the pocket dataset corresponding to the subject user. 

One feature of data object management by pocket server 112 
is worth noting. Pocket served 112 organizes data objects for 
each user according to the date most recently accessed. 
Navigating lists which span several screens in a mobile device 
such as wireless telephone 110 is a considerable inconvenience. 
Accordingly, pocket server 112 assumes that those data objects 
most recently accessed by the subject user, whether through 
client computer 106 or through . wireless telephone 110, are most 
likely to be the next accessed data objects. Therefore, pocket 



U server 112 sorts data objects in pocket dataset 204 for the 

O 

fU subject user from most recently accessed to least recently 

m 

Q accessed. 

15 This feature is illustrated by screen view 3500 (Figure 35) 

in which the stock data object most recently entered as shown in 
Figure 34 is the first item 3504 in the list 3502 of data objects 
of the subject user. When the subject user accesses the list of 
data objects through wireless telephone 110, pocket server 112 

20 presents the data objects to the subject user in the same order 
such that the newly added stock' data object is immediately 
accessible to the subject user. 

The subject user selects a stock data object from a list of 
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data objects in the user's pocket dataset in the manner described 
above for other data objects. In response, mobile system 
interface 210 (Figure 2) retrieves the ticker symbol and market 
of the stock data object from content 508 (Figure 5) and submits 
5 that information to a stock server in the form of a request for 
updated stock information. Stock servers are well-known and are 
not described further herein. Examples of stock servers which 

£ are currently available include E*TRADE of the E*TRADE Group, 

i jj 

p s Inc. ( http: //www. etrade. com ) ; the Nasdaq Stock Market 



ldfi (http: // www. nasdaa.com ) ; the New York Stock Exchange 

yj 
rf 2 

( http: //www. nvse.com ) ; and North American Quotes 

J\ ( http: //www. naa. com ) . Any of servers 104A-C can act as a stock 

o 

server. The stock server responds to the request in a 

§y 
nj 

« conventional manner, supplying the price, date and time of the 

i i 

15~ most recent trade of the identified stock and the change in price 
from the close of the most recently concluded trading period. 

Upon receipt of the updated stock information, mobile system 
interface 210 (Figure 2) constructs a WML deck representing the 
updated stock information and including navigation cards to 

20 facilitate access to associated actions. The initially displayed 
card of the WML deck is shown in Figure 36 and includes the stock 
ticker symbol as the header, a more detailed name of the stock, 
the price and time of the last trade, the change in price since 




— 57 — 



Patent Application Attorney Docket P-2 1 92D3 

the close of the most recently concluded trading period, and the 
name of the exchange on which the stock is traded. 

Upon confirmation by the subject user that this updated 
information has been read, a navigation card of the WML deck is 
presented to the user as shown in Figure 37. The actions include 
those similar to similarly named actions described above, namely, 
a shown details action which returns the subject user to the card 
shown in Figure 37, the send-to-f riend action in which the stock 
data object is added to a pocket dataset associated with another 
user, the erase action in which the subject stock data object is 
removed from the pocket dataset associated with the subject user, 
and the action which returns the subject user to viewing names of 
all data objects in the user's pocket dataset. 

For stock data objects, an update quote action is defined. 
The update quote action is performed by mobile system interface 
210 on behalf of wireless telephone 110. In performing the 
update quote action, mobile system interface 210 again queries a 
stock server for updated information on the subject stock in the 
manner described above and re-constructs the WML deck in the 
manner described above. Mobile system interface 210 sends the 
re-constructed WML deck, which includes freshly updated stock 
information, to wireless telephone 110 for display to the subject 
user in the manner described above. From the perspective of the 
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subject user, invocation of the update quote action returns the 
subject user to the display shown in Figure 36 with the 
information represented therein newly updated. The behavior is 
similar to the show details action listed in Figure 37 except 
5\" that the show details action merely returns to a previously shown 
display and there is no interaction with mobile system interface 
210 and the information shown is not updated. 
H Thus, using all the user interface conveniences of client 

Q computer 106, the subject user can create stock data objects for 

l(fU each of a number of stocks of interest and subsequently access 

Ed 

W current information about those stock which significant ease. 

01 

f With a single key press, the user can retrieve a stock data 



ill 

Hi- 



object representing a particular stock. With two key presses - 
one to access the actions menu and another to invoke the update 



quote action - the subject user can get newly updated information 
about the stock. 



Product Data Objects 

Pocket item types 206 (Figure 2) define a product type of 
20 data object in this illustrative embodiment. The dialog box of 
screen view 3800 (Figure 38) illustrates attributes defined by 
attribute definitions 604 (Figure 6) of the product type of data 
object. Product data objects represent items that the subject 
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user has interest in purchasing. 

The subject user can specify data corresponding to 
attributes defined by attribute definitions 604 (Figure 6) of the 
product type through client computer 106 using a dialog box such 
as that shown in screen view 3800 (Figure 38).- The subject user 
can specify each of the attributes directly using conventional 
user interface techniques. Alternatively, the various attributes 
can be pre-specif ied and embedded in a URL in the manner 
described above with respect to Figure 7. 

lCKj Box 3802 (Figure 38) indicates that the represented data 

SO 

ry object is a product data object. Box 3804 specifies a product 

01 

5 sub-type. In this illustrative embodiment, product sub-types 

M 

Q include car, clothing, book, electronic, furniture, music, and 

ru 

fli video/DVD products. Box 3806 specifies the name or brief 

d 

IS* description of the subject product. The subject product is the 
product represented by the product data object. Box 3808 
identifies the author or manufacturer of the subject product. 
Box 3810 specifies the price of the product. Box 3812 specifies 
a product code by which the subject product is identified. For 

20 example, the product code can be an International Book Serial 

Number (ISBN) is the subject product is a book as shown in Figure 
38 in this illustrative example. 

Box 3814 includes a more detailed textual description of the 
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subject product. Box 3816 includes any notes the subject user 
wishes to add to the product data object. Upon pressing 
confirmation button 3818 by the subject user, base system 
interface 202 receives the HTML form data shown in Figure 38 from 
client computer 106 and constructs therefore a product data 
object and adds the product data object to the pocket dataset 
corresponding to the subject user. 

Further illustrating sorting by pocket server 112, the newly 
added product data object is most recently accessed by either 
client computer 106 or wireless telephone 110 and is there listed 
first as shown in screen view 3900 (Figure 39) . 

When mobile system interface 210 (Figure 2) receives a 
request to display a product data object, e.g., when selected 
from a list of data objects by the subject user in the manner 
described above, mobile system interface 210 retrieves content 
508 (Figure 5) of the requested product data object and builds a 
WML deck which includes the retrieved content formatted as 
product information (as shown in Figure 40) and also includes 
navigation cards and associations with actions associated with 
the product type as specified in actions 208. 

Upon acknowledging reading of the detailed information in 
display 1004 (Figure 40), e.g., by pressing key 1006, wireless 
telephone displays an actions menu card (Figure 41) in display 
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1004. The show details, send to friend, and erase actions shown 
are analogous to similarly named actions for other data object 
types described above. 

In addition, a find nearest action is defined for product 
data objects. The find nearest action is similar to the nearby 
places action defined for place data objects as described above. 
Briefly, the subject user, by invoking the find nearest action, 
is requesting nearby places of a category and subcategory 
associated with the product subtype. Within the product type 
definition, pocket server 112 maintains data associating each 
product subtype with both a directory category and a subcategory. 
In performing the find nearest action associated with product 
data objects, mobile system interface 210 queries a directory 
server as described above in conjunction with the nearby places 
action, supplying the associated place category and subcategory 
associated with the current product data object. 

As described above, such a request for nearby places is for 
places near a place of reference. In the find nearest action for 
product data objects, the point of reference is supplied by the 
subject user. In a manner analogous to that described above with 
respect to specification by the subject user of a location 
defining a trip for which driving directions are sought, the 
subject user specifies a current location relative to which 
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nearby sources for the subject product are sought. Such 
includes, for example, identifying a place object with the pocket 
dataset of the subject user, identifying either airport in a 
flight data object, or specifying a location explicitly such as 
by an address or latitude/longitude coordinates. 

When mobile system interface 210 receives the list of nearby 
places from the directory server, mobile system interface 210 
constructs a WML deck which includes the nearest places received 
and sends the WML deck to wireless telephone 110 for presentation 
to the subject user in the manner described above with respect to 
Figure 24. 

Folder Data Objects 

A folder data object is a data object whose content 508 
(Figure 5) includes one or more references to other objects 
within pocket item dataset 204. The subject user can create 
folder data objects through client computer 106 and assign other 
data object to be included in the created folder. For example, 
the subject user can create a folder which is to contain all data 
object pertaining to a particular trip - for example, a flight 
data object representing the first flight and another 
representing the return flight, and a place data object 
representing each of a hotel in which the subject user is staying 



704 (Figure 7). In particular, the URL can include component 
attributes of both a data object and a folder object which 
contains the data object. In addition, the folder object can 
have an associated action specified in the URL or previously 
specified to pocket server and associated with the source or 
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and various restaurants at which the subject user has plans to 
dine . 

By representing folders using data objects, the ability to 
associate actions in the manner described above is also 
applicable to folders. For example, the subject user can send 
the folder for a particular trip to a friend 416 (Figure 4) to 
communicate an entire itinerary with a single action. 

In addition, a hierarchy of data objects can be specified in 
a single URL such as the one described above with respect to link 



lp provider which is in turn associated with the newly created 
folder data object. For example, a URL in a link at a real 
estate brokerage Web site can include a place object representing 
a particular property for sale and can include a folder object 
representing the real estate brokerage, including the place 

20 object, and specifying an action which links the subject user to 
the WAP site of the real estate brokerage for features and 
information found therein. 
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Pattern Matching 

As described above in conjunction with Figure 7 , specific 
attributes of a data object can be specified in a URL such that 
the subject user can immediately add the data object with a 
single user interface gesture. However, such requires that an 
author of the Web page including the URL embed the attributes of 
the associated data object into the URL to enable this 
particularly useful feature. 

Occasionally, the subject user will want to include a data 
object pertaining to information found on wide area network 102 
that is not pre-conf igured for direct input to pocket server 112 
as a data object ready for storage in the subject user's dataset 
204. Accordingly, pocket server 112 helps automate this process 
by recognizing attributes of data object types in text selected 
by the subject user. 

Screen view 4200 (Figure 42) shows selected text 4202 of a 
Web page shown on client computer 106 during browsing of wide 
area network 102 by the subject user. The subject user selects 
selected text 4202 (Figure 42) using well-known and conventional 
user interface techniques. In addition, the subject user causes 
a pop-up menu 4204 to be presented. A pop-up menu such as pop- 
menu 4204 is typically invoked using a secondary button on a 
pointing device such as an electronic mouse or trackball. The 
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subject user selects option 4206 which is labeled "PocketThis ! " 

Selection of option 4206 sends selected text 4202 to base 
system interface 202 (Figure 2) in conjunction with a request to 
create a new data object for storage in object dataset 204 for 
5 the subject user. In response, base system interface 202 

presents a dialog box 4300 (Figure 43) by which the subject user 
is permitted to modify the data object prior to storage in pocket 
dataset 204 (Figure 2) . Base system interface 202 assumes a 
O default type of data object, namely, a note. A note data object 
1CN is the simplest type of data object in this illustrative 

Hi 

embodiment of the present invention. In particular, a note 

nJ 

includes only subject and text body attributes and supports only 
2 the show details, send to friend, and erase actions described 

above. Accordingly, selected text 4202 (Figure 42) is initially 



ru 



represented as textual body 4302 (Figure 43) of a prospective new 
note data object. 

In this illustrative example, the subject user intents 
selected text 4202 (Figure 42) to be a place data object. 
Accordingly, the subject user selects option 4306 (Figure 43) 
20 from a pull-down menu 4304 to indicate that the newly created 

data object should be a place data object. Pull-down menus are 
known and conventional user interface mechanisms and are not 
described further herein. 
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In response to indication by the subject user that the newly 
created data object should be a place data object, base system 
interface 202 retrieves an attribute pattern 606 (Figure 6) of 
pocket item type 206 according to which base system interface 202 
parses attributes defined by attributed definitions 602. Parsing 
of telephone numbers and addresses is well-known and conventional 
and is not described further herein. 

Once text body 4302 (Figure 43) is parsed by base system 



q interface 202, base system interface 202 presents a dialog box 

z r 

lCNj 4400 as an HTML form within a Web page to client computer 106 
ry thus allowing the subject user to verify and/or correct the 

m 

£ parsing of the place attributes prior to confirmation in the 
Q manner described above. Upon confirmation by the subject user, 

ru 

fy. base system interface 202 receives the HTML form data specifying 
1^. the respective attributes of the new place data object, 

constructs the new place data object using the form data, and 
stores the new place data object in the subject user's pocket 
dataset 204. The new place data object is shown in the subject 
user's pocket dataset 204 in screen view 4500 (Figure 45). 
20 Thus, the user can easily and quickly add new data objects 

based on data found in Web pages or other documents not otherwise 
prepared for automatic creation of pocket data objects. 



— 67 — 



1 



Patent Application Attorney Docket P-2 1 92D3 

Tracking of Browsing bv the Subject User 

As described above, access of a particular data object by 
the subject user moves that data object to the beginning of the 
list of data objects in the pocket dataset 204 of the subject 
user. In this illustrative embodiment, base system interface 202 
updates access time 506 (Figure 5) in accordance with the most 
recent access of data object 306. Subsequently, in displaying 
data objects of the pocket dataset 204 associated with the 
subject user, base system interface 202 (if the subject user is 



lQsj listing the data objects on client computer 106) or mobile system 

m 

rn interface 210 (if the subject user is listing the data objects on 

m 

m. wireless telephone 110) sorts the data object by most recent 

y% access time. In an alternative embodiment, pocket server 112 

fii maintains a sequence data field (not shown) in data object 306 

m 

ltj which is set each time data object 306 is accessed by the subject 
user to thereby enable sorting of data objects according to 
recency of access. In another alternative embodiment, data 
object 306 includes one or more pointers (not shown) to other 
data objects in the subject user's pocket dataset 204 (Figure 3) 

20 and pocket server 112 maintains an ordered linked list of data 

objects in each pocket dataset according to recency of access by 
the associated user. 

In this illustrative embodiment, the subject user does not 
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need to explicitly view a data object in her pocket dataset 204 



to move that data object to the beginning of the list of data 



objects. Mere viewing of a Web page in which the substance of 



the data object is represented is sufficient. 



5 



To illustrate this feature, it is helpful to consider the 



example of the subject user's visiting the Web page shown in 



screen view 702 (Figure 7) after link 704 has been used to add 



the place object to the user's dataset 204 in the manner 




described above. 



In this illustrative example, the Web page of screen view 



flj 702 is served by a server such as any of servers 104A-C. In this 

m 

e illustrative example, this Web page is served by server 104A. In 

M 

Q serving the Web page, server 104A stores a document which defines 

fy the content of screen view 702 in HTML (Hyper-Text Markup 



1§* Language) and presents the document in response to a request for 
the document in the form of a URL identifying the document. Such 
a URL includes identification of server 104A as the server for 
the Web page defining screen view 702. Such identification is 
typically a domain name or an Internet Protocol (IP) address. 

20 HTML documents are well-known and conventional. However, to 

facilitate appreciation and understanding of the present 
invention, certain aspects of HTML documents are described 
briefly herein. It is common for HTML document to include other 



D 
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embedded documents. In fact, since HTML is a textual language 
and HTML document include only text, all images, sounds, and 
active scripts in Web pages are defined by separate documents 
which are included in the HTML document by reference - by the URL 
of the embedded separate document. Such embedded documents can 
be served by a different server than the server serving in the 
embedding HTML document. ' In this illustrative example, 
photograph 708 (Figure 7) is included by reference and is served 
by a different server, e.g., server 104B. 

When the subject user requests the Web page of screen view 
702 by use of the URL thereof, client computer 106 sends the URL 
through wide area network 102 to server 104A. Server 104A 
responds by sending the HTML document of the Web page. In 
displaying the Web page, client computer 106 encounters the 
embedded URL for photograph 708 and sends the photograph URL 
through wide area network 102 to server 104B which responds by 
sending a data file which represents photograph 708. Until the 
subject user activates link 704, pocket server 112 normally has 
no awareness of or interaction with client computer 106 or 
servers 104A-B related to the viewing of the Web page by the 
subject user. 

However, the Web page shown in screen view 702 is configured 
to inform pocket server 112 of the fact that the subject user has 
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visited the Web page of screen view 702. In particular, the HTML 
document defining the Web page of screen view 702 includes an 
embedded item served by pocket server 112 such that pocket server 
112 is involved in the display of the Web page of screen view 
5 702. Specifically, a single pixel 710 which is the same color as 
the background of the subject Web page is served by pocket server 
112. 

In addition to making pocket server 112 aware of the display 
Q of the Web page, pocket server 112 is notified as to the 

10W particular user displaying the Web page and the particular pocket 

FIJ 

H data object associated with the Web page. To inform pocket 

!U 

P 1 server 112 as to which Web page is being displayed, both link 704 

tl and 710 include the URL of the Web page of screen view 702 

O 

SB 8 

L? 1 embedded therein. When pocket server 112 stores a data object as 

ru 

15f a result of activation of link 704, pocket server 112 receives 

the URL of the Web page of screen view 702 and associates the URL 
with the stored data object. Accordingly, the URL of the Web 
page of screen view 702 can be used by pocket server 112 to 
identify which of the data object within pocket datasets 204 

20 (Figure 2) corresponds to the Web page of screen view 702 (Figure 
7) . 

To identify the subject user as the particular user browsing 
the Web page of screen view 702, pocket server 112 uses a cookie. 
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Cookies and their use are known and conventional. Briefly, a 
cookie is a unique identifier by which a server recognizes a 
previously served client. The first time the subject user views 
the Web page of screen view 702, there is no cookie placed there 
by pocket server 112. Accordingly, pocket server 112 does not 
recognize the user. Pocket server 112 stores a cookie on client 
computer 106 such that subsequent views of the Web page of screen 
view 702 enable recognition of the subject user by pocket server 
112. In this illustrative embodiment, the subject user places 
the place data object represented by link 704 in the pocket 
dataset associated with the subject user in the manner described 
above in this first visit. 

When the subject user subsequently visits the Web page of 
screen view 702, the embedded pixel 710 informs pocket server 112 
of the viewing of the Web page. In serving embedded pixel 710, 
pocket server 112 retrieves the cookie identifying the subject 
user. Accordingly, pocket server 112 knows the identity of both 
the subject user and the place data object described in the 
viewed Web page. 

As a result of the subject user's visit to this Web page, 
pocket server 112 assumes that the described data object was 
viewed by the subject user, albeit served by a different server 
through wide area network 102. Pocket server 112 therefore 
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updates the order in which data objects are presented to the 
subject user, through both client computer 106 and wireless 
telephone 110. 

Thus, by merely viewing the Web page of screen view 702, the 
data object representing place data 706 is the first item listed 
when subsequently accessed through wireless telephone 110. In 
essence, the subject user's pocket dataset 204 is perpetually 
updated to reflect items determined to be of interest to the 
subject user - even, when the subject user is not directly ' 
interacting with pocket server 112. 

Thus, a mechanism is provided by which pocket server 112 is 
notified when data associated with a particular data object is 
accessed by a particular user. It should be appreciated that 
different levels of access can be notified. For example, pocket 
server 112 can be notified in the manner described above when 
substantive content 706 (Figure 7) is displayed to the subject 
user. Similarly, any of servers 104A-C providing a Web page 
which includes a link to the Web page of screen view 702 can 
similarly notify pocket server 112 that the subject user has 
accessed information which is apparently relevant to content 706. 

Mobile system interface 210 (Figure 2) similarly updates 
access time 506 (Figure 5) when the user has accessed data object 
306 through wireless telephone 110. In various embodiments, 
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different levels of access are required before access time 506 is 
updated. In one embodiment, time accessed 508 is updated when 
data object 306 is presented in a list of data objects to the 
subject user through wireless telephone 110, In an alternative 
5 embodiment, time accessed 508 is updated when the details of data 
object 306 are viewed by 'the subject user. In another 
embodiment, time accessed '50' 8 is updated when the subject user 
M, requests a list of applica&le actions for data object 306. 

lQRj Off-Line Identification of ,.Pr:e,^Stored Data Objects 

m 

iU Having users moving about ' with complete access to a vast, 

m 

5 wide area network such as the Internet provides advertisers with 

H» ■ ' ' " 

□ a tremendous opportunity to g'irafit access to their products and 

m 

W services. However, much advertising is through mass media when 

Q 

1^ the targeted customers are not using or near their computers. 

The data objects described herein, being organized into 
attributes on which actions can act, provide a convenient, 
orderly access point for users of mobile devices to access the 
vast amount of information available through Internet-capable 
20 mobile devices. In addition, typical WAP URLs - being 

alphanumeric - are particularly difficult to enter using the 
typical numeric keypad 1002 available with most mobile devices. 
Accordingly, pocket server 112 allows data objects such as 
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data object 306 to be stored independently of any user and 
associated with a numerical identifier. Accordingly, a data 
object representing a restaurant - with all the attributes 
individually specified and all relevant actions properly defined 
5 - can be pre-created and stored within pocket server 112 and 

associated with a numerical identifier. The restaurant can be 
advertised on television, radio, billboards, in airports and 
O train stations, in newspapers, etc. - all places which compete 

I : 

W for customers' attention when the customer is away from her 

fU 

lCW computer. 

y ? If a customer is interested in the restaurant, the customer 

can - through wireless telephone 110 which is immediately 

O 

^ accessible to the customer while out and about - select a "Pocket 

m 

by Number" action and provide the numerical identifier. Since 
15 the identifier is numerical, the customer can readily enter it 

using the numerical keypad 1002 of the typical mobile device. 

Even mobile devices such as PDAs which support textual input have 

difficulty with punctuation and other symbols typically included 

in URLs - WAP or otherwise. Accordingly, the simplicity of 
20 numerical identifiers significantly improves the ease with which 

the user can specify the identifier in these other forms of 

mobile devices. 

Thus, the customer has access to the restaurant in the form 
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of its name, address, an auto-dial action, driving directions, 
directories of nearby places, etc. all by entering several digits 
of a numerical identifier of the restaurant. Such represents 
tremendous economy in the amount of user effort compared to the 
amount of useful information obtained by such effort in a mobile 
information platform. 

The above description is illustrative only and the present 
invention is defined solely by the claims which follow and their 
full range of equivalents. 



